package com.ctsi.ssdc.service;

import com.ctsi.ssdc.entity.IndustrialEconomicIndicators;
import org.apache.ibatis.annotations.Delete;
import org.apache.ibatis.annotations.Param;
import org.springframework.data.domain.Page;
import org.springframework.data.domain.PageRequest;

import java.util.Date;
import java.util.List;
import java.util.concurrent.Future;

/**
 * 工业经济主要指标(IndustrialEconomicIndicators)表服务接口
 *
 * @author makejava
 * @since 2023-03-11 22:08:06
 */
public interface IndustrialEconomicIndicatorsService {

    /**
     * 通过ID查询单条数据
     *
     * @param id 主键
     * @return 实例对象
     */
    IndustrialEconomicIndicators queryById(Long id);

    /**
     * 分页查询
     *
     * @param industrialEconomicIndicators 筛选条件
     * @param pageRequest      分页对象
     * @return 查询结果
     */
    Page<IndustrialEconomicIndicators> queryByPage(IndustrialEconomicIndicators industrialEconomicIndicators, PageRequest pageRequest);

    /**
     * 新增数据
     *
     * @param industrialEconomicIndicators 实例对象
     * @return 实例对象
     */
    IndustrialEconomicIndicators insert(IndustrialEconomicIndicators industrialEconomicIndicators);

    /**
     * 修改数据
     *
     * @param industrialEconomicIndicators 实例对象
     * @return 实例对象
     */
    IndustrialEconomicIndicators update(IndustrialEconomicIndicators industrialEconomicIndicators);

    /**
     * 通过主键删除数据
     *
     * @param id 主键
     * @return 是否成功
     */
    boolean deleteById(Long id);

     /**
     *  批量添加数据
     * @param list
     * @return 是否成功
     */
     boolean insertBatch(List<IndustrialEconomicIndicators> list);

    @Delete("DELETE FROM trade_and_service_industry\n" +
            "WHERE indicators = #{name}\n" +
            "AND DATE_FORMAT(statisticalTime,'%Y-%m') = #{date}")
    boolean removeByIndicator(@Param("date") Date date, @Param("name") String name);

    /**
     * 根据日期删除
     * @param date
     * @return 是否成功
     */
    boolean removeByDate(Date date);


}
